<template>
  <el-dialog :title="title" :visible="isShowDept" :before-close="handleClose" @open="handleOpen">
    <span>
      <!-- 匿名插槽 -->
      <el-form ref="addRef" :model="form" :rules="rules" label-width="120px">
        <el-form-item label="部门名称" prop="name">
          <el-input v-model="form.name" style="width:80%" placeholder="1-50个字符" />
        </el-form-item>
        <el-form-item label="部门编码" prop="code">
          <el-input v-model="form.code" style="width:80%" placeholder="1-50个字符" />
        </el-form-item>
        <el-form-item label="部门负责人" prop="manager">
          <el-select v-model="form.manager" style="width:80%" placeholder="请选择">
            <el-option label="请选择负责人" :value="null" />
            <el-option v-for="item in list" :key="item.id" :lable="item.username" :value="item.username" />
          </el-select>
        </el-form-item>
        <el-form-item label="部门介绍" prop="introduce">
          <el-input v-model="form.introduce" style="width:80%" placeholder="1-300个字符" type="textarea" :rows="3" />
        </el-form-item>
      </el-form>
    </span>
    <span slot="footer" class="dialog-footer">
      <el-button @click="handleClose">取 消</el-button>
      <el-button type="primary" @click="handleSubmit">确 定</el-button>
    </span>
  </el-dialog>
</template>

<script>
import { getEmployeeSimple } from '@/api/employees.js'
import { reqAddDepartments, reqGetDepartDetail, reqUpdateDepartments } from '@/api/departments.js'

export default {
  name: 'AddDept',
  props: {
    // 控制添加部门弹窗标志位
    isShowDept: {
      type: Boolean,
      required: true
    },
    // 当前父级部门
    currentPid: {
      type: String,
      required: true
    },
    // 所有部门的数据
    dlist: {
      type: Array,
      default: () => []
    },
    operateType: {
      type: String,
      default: 'add'
    }

  },
  data () {
    // 自定义验证规则：验证部门名称
    const checkName = (rule, value, callback) => {
      // 同级部门的名称不可以重复
      // value 就是当前添加的子部门名称
      // 1、找到同级部门信息：根据父级部门的id
      // 父级部门的id=子级部门的pid，
      let flag = null
      if (this.operateType === 'add') {
        const list = this.dlist.filter(item => {
          // 如果行政部添加子部门，currentPid 就是当前父级部门的id
          // 如果编辑行政部，currentPid 就是当前部门的id
          return item.pid === this.currentPid
        })
        // 2、判断输入的部门名称和同级部门名称是否冲突
        flag = list.find(item => {
          return item.name === value
        })
      } else {
        // 编辑部门验证：排除自己
        // 1. 查找同级部门：当前部门的父id如果一样，就属于同级部门
        const list = this.dlist.filter(item => item.pid === this.form.pid)
        // 2. 判断value是否在同级部门中已经存：排除自己
        flag = list.find(item => item.name === value && item.id !== this.form.id)
      }
      // 判断存在性
      if (flag) {
        // 重复了
        callback(new Error('同级部门名称不可以重复'))
      } else {
        // 不重复
        callback()
      }
    }
    const checkCode = (rule, value, callback) => {
      let flag = null
      if (this.operateType === 'add') {
        // 部门编码全局不可以重复
        flag = this.dlist.some(item => {
          return item.code === value
        })
      } else {
        // 编辑时表单验证：全局不可以重复，但是排除自己
        flag = this.dlist.some(item => item.code === value && item.id !== this.currentPid)
      }
      if (flag) {
        // 重复了
        callback(new Error('部门编码不可以重复'))
      } else {
        // 不重复
        callback()
      }
    }
    return {
      // 获取负责人列表
      list: [],
      // 表单验证
      rules: {
        name: [
          { required: true, message: '部门名称不能为空', trigger: ['blur', 'change'] },
          { min: 1, max: 50, message: '部门名称要求1-50个字符', trigger: ['blur', 'change'] },
          { validator: checkName, trigger: ['blur', 'change'] }

        ],
        code: [
          { required: true, message: '部门编码不能为空', trigger: ['blur', 'change'] },
          { min: 1, max: 50, message: '部门编码要求1-50个字符', trigger: ['blur', 'change'] },
          { validator: checkCode, trigger: ['blur', 'change'] }
        ],
        manager: [
          { required: true, message: '部门负责人不能为空', trigger: ['blur', 'change'] }
        ],
        introduce: [
          { required: true, message: '部门介绍不能为空', trigger: ['blur', 'change'] },
          { min: 1, max: 300, message: '部门介绍要求1-300个字符', trigger: ['blur', 'change'] }
        ]
      },

      // 当前点击哪个部门的数据
      form: {
        id: '',
        pid: '',
        name: '', // 部门名称
        code: '', // 部门编码
        manager: '', // 部门管理者
        introduce: '' // 部门介绍
      }
    }
  },
  computed: {
    title () {
      return this.operateType === 'add' ? '添加部门' : '编辑部门'
    }
  },
  methods: {
    async loadDeptInfo () {
      const ret = await reqGetDepartDetail(this.currentPid)
      if (ret.code === 10000) {
        // 获取成功
        // this.form.id = ret.data.id
        // this.form.name = ret.data.name
        // this.form.code = ret.data.id
        // this.form.manager = ret.data.manager
        // this.form.introduce = ret.data.introduce

        this.form = ret.data
        // console.log(ret)
        // for (const key in this.form) {
        //   this.form[key] = ret.data[key]
        // }
      }
    },
    // 获取负责人列表
    async handleOpen () {
      // 如果点击的是编辑按钮
      if (this.operateType === 'edit') {
        // 此时正在编辑部门
        this.loadDeptInfo()
      }
      try {
        const ret = await getEmployeeSimple()
        // console.log(ret)
        if (ret.code === 10000) {
          // 获取列表成功
          this.list = ret.data
          // console.log(this.list)
        }
      } catch {
        this.$messgae.error('获取负责人列表失败')
      }
    },
    // 提交表单
    handleSubmit () {
      // 兜底验证
      this.$refs.addRef.validate(async (valid) => {
        if (valid) {
          // 验证通过
          if (this.operateType === 'add') {
            // 提交部门数据
            try {
              const ret = await reqAddDepartments({
                ...this.form,
                // 父级部门当前id
                pid: this.currentPid
              })
              if (ret.code === 10000) {
                // 刷新列表
                this.$emit('on-success')
                // 关闭弹窗
                this.$emit('update:isShowDept', false)
                this.$message.success('添加成功')
                this.handleClose()
              }
            } catch {
              this.$message.error('添加失败')
            }
          } else if (this.operateType === 'edit') {
            try {
              // 编辑部门提交表单
              const ret = await reqUpdateDepartments(this.form)
              if (ret.code === 10000) {
                this.$emit('on-success')
                this.$message.success('添加成功')
                this.handleClose()
              }
            } catch {
              this.$message.error('编辑失败')
            }
          }
        }
      })
    },
    handleClose () {
      // 通知父组件关闭弹窗
      // this.$emit('toggle-box', false)
      // sync修饰符传递的数据要求出发事件的格式  update:属性名称
      this.$emit('update:isShowDept', false)
      // 弹窗关闭时清空表单
      this.$refs.addRef.resetFields()
    }
  }

}

</script>
